

Henrique Coutinho Layber e Renan Moreira Gomes

# IMPLEMENTAÇÃO DE UMA UNIDADE LÓGICA E ARITMÉTICA COM PORTAS LÓGICAS BÁSICAS

Professor Dr. João Paulo de Almeida
Universidade Federal do Espírito Santo
Ciência da Computação
Vitória, Espírito Santo, 2018

### Sumário

i. Conceitos; ii. Explicando a ALU; iii. Código de Operações; iv. Cada circuito explicado; a. or bit-a-bit; b. AND bit-a-bit; c. xor bit-a-bit; 1. xor 1 bit; 2. xor 8 bits; d. Somadores; 1. 1 bit; 2. <u>8 bits</u>; e. Subtrator; f. Shift Left; g. Shift Right; h. Multiplexadores; 1. <u>2:1 1 bit;</u> 2. <u>2:1 8 bits</u>; 3. <u>8:1 8 bits</u>; v. Igual a 0 (saída Z); vi. Displays hexadecimais;

vii. Montando a ALU;

viii. Unindo as ALUs;

ix. Anexo 1;

### Conceituando a ALU

Unidade Lógica Aritmética (*Arithmetic Logic Unit – ALU*)é uma unidade lógica aritmética é um elemento central em uma CPU (Unidade de Processamento Central). Ela executa operações lógicas e aritméticas básicas diversas em dados de entrada, mas podemos juntá-las e usar das basicas para formar ALUs mais complexas. Iremos explicar passo a passo como projetar uma ALU que opere sobre dados de 8 bits, e como usar a mesma para montar uma ALU de 16 bits, como uma calculadora básica.

### Especificação

Nossa ALU final irá conter as seguintes operações em cima das entradas A e B de 16 bits:

- ADD soma (A + B);
- SUB subtração (A B);
- XOR bit-a-bit (A XOR B);
- OR bit-a-bit (A OR B);
- AND bit-a-bit (A AND B);
- SHL Shift left (A << 1 desloca os bits de A para a esquerda);</li>
- SHR Shift right (A >> 1 desloca os bits de A para a direita).

Além dos operandos A e B de 8 bits, nossa ALU irá conter uma entrada OP de 3 bits que indica a operação a ser realizada com os operandos. A ALU irá seguir a seguinte tabela para a operação OP:

A ALU inicial também terá um carry de entrada (Cin), que permitirá depois concatenar duas ALUs de 8 bits para formar uma ALU de 16 bits, e as saídas de ambas deverão funcionar da seguinte forma:

| Valor de OP | Saída                    |  |  |  |  |
|-------------|--------------------------|--|--|--|--|
| 000         | ADD Soma (A + B)         |  |  |  |  |
| 001         | SUB subtração (A - B)    |  |  |  |  |
| 010         | XOR bit-a-bit (A XOR B)  |  |  |  |  |
| 011         | OR bit-a-bit (A OR B)    |  |  |  |  |
| 100         | AND bit-a-bit (A AND B)  |  |  |  |  |
| 101         | SHL Shift left (A << 1)  |  |  |  |  |
| 110         | SHR Shift right (A >> 1) |  |  |  |  |
| 111         | Não usada                |  |  |  |  |

Tabela a: Valor de OP e respectiva operações

- Uma saída C indicando carry (1 em C indica que houve carry)
   (no caso de subtração, indica borrow, no caso da operação SHL,
   o carry recebe o bit mais significativo sendo deslocado; no caso de
   SHR, recebe o bit menos significativo, em soma, indica Overflow);
- Uma saída Z que indica se todos os bits da saída são iguais a 0 (1 em Z indica que todos os bits da saída S são 0);
- Uma saída S de 8 bits com o resultado numérico da operação, e dois dígitos de display de 7 segmentos para mostrar o resultado.<sup>1</sup>

<sup>1</sup> Não será feito display hexadecimal para a ALU de 16 bits, pois a sua implementação é mais complexa. Henrique Coutinho Layber e Renan Moreira Gomes

|      | Observe na imagem abaixo, todas as entradas e saidas que serao |
|------|----------------------------------------------------------------|
|      | utilizadas como base para a definição da ALU:                  |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
|      |                                                                |
| Illu | ustration a: Entradas e saídas da ALU                          |

### Cada circuito da ALU

É muito mais simples construir um circuito para 8 bits do que 12 deles de uma só vez. É por isso que buscamos modularizar o máximo possível – e para a resolução de problemas (bugs). Somente alguém insano faria tudo de uma só vez. É claro que poderíamos poupar algumas comparações (e consequentemente performance ou dinheiro) por fazer sem a modularização, mas como o objetivo da nossa ULA é fazer apenas uma das operações de cada vez, não haverá tanto impacto.

# Comparação OR bit-a-bit (A OR B):

A comparação OR é um circuito de relativamente simples implementação, principalmente por ele ser uma operação bit-a-bit. Então é um simples caso de aplicar a operação a cada bit separadamente para expandir ele para uma operação de 8 bits e então juntar em uma saída de 8 bits:



# Comparação AND bit-a-bit (A AND B)

Tal como a comparação OR, a comparação AND também é aplicada bit-a-bit, então podemos aplicar o mesmo método para essa operação e o resultado devera ser A AND B (8bits):



### Comparação XOR bit-a-bit (A XOR B)



Henrique Coutinho Layber e Renan Moreira Gomes Universidade Federal do Espírito Santo Vitória 2018

modularização ser útil.

### ADD soma (A + B)

Para realizar a soma de 8 bits, devemos criar inicialmente um somador completo de 1 bit a partir da tabela 2, observe a imagem abaixo:

| А | В | Cin | S | Cout |
|---|---|-----|---|------|
| 0 | 0 | 0   | 0 |      |
| 0 | 0 | 1   | 1 | 0    |
| 0 | 1 | 0   | 1 | 0    |
| 0 | 1 | 1   | 0 | 1    |
| 1 | 0 | 0   | 1 | 0    |
| 1 | 0 | 1   | 0 | 1    |
| 1 | 1 | 0   | 0 | 1    |
| 1 | 1 | 1   | 1 | 1    |

Table a: Tabela-Verdade do somador de 1 bit completo

Usando a tabelaverdade, fica fácil constuir
um somador completo (de 1
bit), e usamos a saí Cout
(carry out) para levar
uma entrada "sobe um" de
uma soma. Note que os
carrys, dependendo da
operação, podem carregar

Illustration f: Somador de 1 bit completo

diferentes valores, com diferentes significados.

Illustration g: Carry de uma soma

|       | Com      | o soma   | ador de   | um bit  | completo,  | basta     | encadeá-lo | 8 | vezes |
|-------|----------|----------|-----------|---------|------------|-----------|------------|---|-------|
| usa   | ando os  | s carry  | y para fo | ormar o | somador de | e 8 bits: |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
|       |          |          |           |         |            |           |            |   |       |
| Illus | stration | h: Somad | or 8 bits |         |            |           |            |   |       |

E, assim, toda a *i<u>llustration g</u>* forma o módulo de soma da ALU.

### Subtração (A - B)

Irônicamente, o circuito de soma será usada para definir o circuito de subtração. Por ser feito as operações em base binária, pode-se abusar de propriedades super úteis como a representação em complemento a dois², e A e B poderão então serem somados se representamos B de forma negativa no complemento a dois. Para fazer isso, só é preciso inverter B  $(0\rightarrow1$  e  $1\rightarrow0$ ) e somar um. Como isso seria complicado, outra estratégia é somar 1 à primeira soma, pois (2 + (-1)) + 1 = (2 + (-1 + 1)).

Illustration i: Subtração 8 bits

<sup>2</sup> Complemento a dois é uma representação binária positiva e negativa, onde, diferentemente do complemento a um, não há a dupla representação do zero e nela, bem como na matemática convencional, (5) + (-2) = 3.
Para isso ser válido, todos os números devem estar representados em complemento a dois (inclusive a saída).
Henrique Coutinho Layber e Renan Moreira Gomes

### Shift Left (SHL)

A operação Shift Left leva cada bit ao dígito à esquerda (parecido com uma multiplicação por 2), à direita entra zeros, e o bit que "cai pra fora" do tamanho especificado deve ser carregado pelo Cout, pois ao encadearmos duas ALUs, ele será passado para a próxima sessão de 8 bits (mais no cap iv. Unindo as ALUs). Então, é só uma questão de reconexão dos bits de entrada na saída:

Illustration j: Shift Left 8 bit

Note que o pino 0 da saída não está ligado a nenhum bit de entrada, mas está aterrado (é o mesmo que constante 0). Isso ocorre pois à medida que o valor se desloca a esquerda, zeros aparecem preenchendo à direita.

E também que o MSD (*Most Significant Digit* – Dígito Mais Significativo) da entrada leva à saída carry separada, Cout.

### Shift Right (SHR)

Extendendo as possibilidades com os shifts, com o SHR apenas desloca todos os bits da entrada, levando o LSD (*Least Significant Digit* – Dígito Menos Siginificativo) para o Cout, e aparecendo zeros à esquerda, semelhando à um resultado de uma divisão por 2, isso pode ser facilmente e efetivamente feito for *rewiring* (religação) das entradas:

*Illustration k: Shift Right 8 bits* 

### Multiplexadores

É preciso escolher qual das operações serão realizadas, e para isso é eficiente um circuito característico denominado *multiplexador*. Eles são característicos pois agem como se fossem chaves seletoras (muitas vezes chamados assim), permitindo que um código de operação controle qual das entradas ele repete na única saída (também há o inverso – em qual das saídas ele repete a única entrada – os demultiplexadores).



| Agora pode-se usar o MUX 2:1 de 8 bits para construir o MUX 8:1 de |
|--------------------------------------------------------------------|
| 8 bits, o que de fato selecionará a operação a ser realizada:      |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
|                                                                    |
| Illustration n: MUX 8:1 8 bits                                     |

Foram implementados multiplexadores conjuntos para a operação e para o carry, partindo do mesmo operador, de forma a somente informar que ocorreu carry quando essa informação é relevante. Pois como as saídas para os operadores de AND, OR, XOR e o não usado deve ser 0, aterra-se a entrada onde o operador selecionaria esses dados:

Illustration o: MUX carry (4:1 1 bit)

# Igual a 0

Como o nome perfeitamente escolhido sugere, esse circuito verifica se a entrada (no caso, de 8 bits) é igual a 0. É um tanto simples uma vez que já foi feito o circuito AND bit-a-bit, e conhecendo a tabela-verdade de valores do AND, pode-se simplesmente inverter cada bit da entrada e passar por um AND com ele mesmo (assim todos devem ser iguais a 1 para sair resultado 1, porém eles foram invertidos e na realidade seriam todos iguais a 0:

*Illustration p: Igual a 0 (8 bits)* 

# **Display Hexadecimal**

| Ao inves de construir um circuito pre-definido pro display, ao inves     |
|--------------------------------------------------------------------------|
| disso pode ser usado multiplexadores e usá-la como linhas da tabela-     |
| verdade (dessa forma o circuito continua grande, mas legível). Então     |
| define-se um multiplexador 16:1 de 1 bit, e ele foi usado como linhas da |
| tabela-verdade para ligar o display 7-segmentos <sup>3</sup> :           |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |
|                                                                          |

Illustration q: MUL 16:1 (1 bit)

<sup>3</sup> O decodificador pode ser encontrado no <u>Anexo 1</u>. Ele foi removido do capítulo original graças ao seu tamanho e em prol da extensão e legibilidade do relatório.

### Montando a ALU

Agora que temos todas as operações prontas, basta montar usando as peças já feitas: das entradas A e B, que são distribuídas de acordo com cada operação, e coletadas em um multiplexador usando a entrada de operação (Op) como chave seletora. Essa chave seletora também seleciona a saída C (carry), e da saída, usamos o circuito Igual\_a\_0 para verificar se a saída esta igual a zero e esta é a saída Z. Basta montar o display, usando 4 bits de cada vez em um decodificador hexadecimal (um para cada dígito):

Illustration r: ALU 8 bits

### Unindo as ALUs

|    | Ag     | ora, | С | omo   | tudo  | foi | moi   | ntad | o co  | rreta | mente  | e, sin | nples | mente   | ligar      |
|----|--------|------|---|-------|-------|-----|-------|------|-------|-------|--------|--------|-------|---------|------------|
| m  | netad  | e d  | е | cada  | entr  | ada | de    | 16   | bits  | em    | uma    | ALU    | , cor | catena  | ır os      |
| re | esulta | dos  | е | ligar | os ca | rry | 's, d | eve- | se cl | nega  | r ao r | esulta | do es | sperado | <b>)</b> : |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |
|    |        |      |   |       |       |     |       |      |       |       |        |        |       |         |            |

Illustration s: ALU 16 bits

# **ANEXO 1**

Henrique Coutinho Layber e Renan Moreira Gomes Universidade Federal do Espírito Santo Vitória 2018

Illustration t: Decodificador dislay 7 segmentos